# **Introduction to Clock Constraints Demo Script**

## Introduction

This demonstration script provides high-level instructions on how to constrain the clock and perform basic timing analysis in a design using the Vivado® Design Suite.

### Preparation:

 Required files: Necessary files are located at C:\training\ClkConstr\_Intro\demo\ KCU105\verilog

• Required hardware: None

Supporting materials: None

#### **Clock Creation**

|   | Action with Description                                                                                      | Point of Emphasis and Key Takeaway                                                         |
|---|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| • | Launch the Vivado Design Suite 2018.1.                                                                       |                                                                                            |
| • | Open the <b>wave_gen.xpr</b> design in the <i>C:\training\ClkConstr_Intro\demo\KCU105\verilog</i> directory. |                                                                                            |
| • | Open the wave_gen_timing.xdc file.                                                                           | Note that there are no timing constraints entered in the XDC file.                         |
|   |                                                                                                              | You will be entering the clock constraints for the design by using the Constraints Wizard. |
| • | Open the synthesized design.                                                                                 |                                                                                            |

|   | Action with Description                                                                                                                                       | Point of Emphasis and Key Takeaway                                                                                                                                                                                                                        |
|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • | Launch the Constraints Wizard from Synthesis > Open Synthesized Design to make the initial clock constraints on the design.                                   | The Constraints Wizard guides you through creating timing constraints. It analyzes the design for missing timing constraints and makes recommendations.                                                                                                   |
| • | Examine the message in the No<br>Target Constraints File dialog box.                                                                                          | From the No Target Constraints File dialog box, it is evident that you need to make the appropriate constraints set and constraint file <b>active</b> before making constraints using the Constraints Wizard.                                             |
| • | Click <b>Define Target</b> in the dialog box to select the target constraints file.                                                                           |                                                                                                                                                                                                                                                           |
| • | Select the wave_gen_timing.xdc constraints file in the Define Constraints and Target dialog box. Click <b>OK</b> .                                            | The Define Constraints and Target dialog box allows you to either select an existing constraints set or create a new one to make an active constraints set.  Now you have assigned the wave_gen_timing.xdc constraint file as the target constraint file. |
| • | Open the Constraints Wizard again.  Click <b>Next</b> in the Welcome page of the Constraints Wizard to identify any missing timing constraints in the design. | The Constraints Wizard is designed to make it as easy as possible to make complete constraints for any design (hence all the questions). In this case, wave_gen does not need any special timing constraints.                                             |

|   | Action with Description                                                                                                                                                    | Point of Emphasis and Key Takeaway                                                                                                                                                                                                      |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • | Enter <b>300</b> MHz in the Frequency column of the Primary Clocks dialog box to apply the missing clock constraint. The Period column gets updated to 3.333 ns.           | The Primary Clocks dialog box in the Constraints Wizard identifies the missing primary clocks, if any in the design, and allows you to enter the period/frequency of the primary clock.                                                 |
| • | Click <b>Skip to Finish</b> after entering the clock constraint.  Select the <b>View Timing Constraints</b> option in the Constraints Summary page.  Click <b>Finish</b> . | The Summary window will acknowledge the new clock constraint. The utility will then close without opening the Constraints Editor.  The Constraints Editor will then open and show the new clock constraint.                             |
| • | Enter report_clocks in the Tcl Console. Make sure to press the <enter> key.</enter>                                                                                        | Describe the contents of this report.  From the Clocks report, what is the input clock to the MMCM?  How many output clocks are generated from this MMCM?                                                                               |
| • | Open the <b>clk_gen.v</b> file from the Sources window.                                                                                                                    | Verify that the signals clk_pin_p, clk_out1, and clk_out2 are made from the clk_core (bottom of file).  From this you will see that clk_rx and clk_tx are out1 and out2. This matches the output signal names from the top of the file. |
| • | Double-click the <b>clk_core.xci</b> file in the Sources window. This will open the Re-customize IP Wizard.  Close the Re-customize IP Wizard without saving any changes.  | Review the output frequencies generated by the MMCM.  Can you explain how this MMCM was configured to produce clocks of 200 MHz and 193.75 MHz? <b>Hint:</b> Go to the Summary tab.                                                     |

|   | <b>Action with Description</b>                            | Point of Emphasis and Key Takeaway                                                  |
|---|-----------------------------------------------------------|-------------------------------------------------------------------------------------|
| • | Click <b>Report Clock Networks</b> in the Flow Navigator. | Review how the report generated confirms how the MMCM made the three output clocks. |

# **Basic Static Timing Analysis**

|   | Action with Description                                                                             | Point of Emphasis and Key Takeaway                                                                                                                                                                                                                                                           |
|---|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • | Rerun synthesis (two or three minutes) and open the synthesized design.                             |                                                                                                                                                                                                                                                                                              |
| • | Click <b>Report Timing Summary</b> to generate a Timing Summary report from the synthesized design. | <ul> <li>Review the following:</li> <li>Organization of the report in the GUI</li> <li>Design Timing Summary</li> <li>Check Timing Report</li> <li>Intra-Clock paths</li> <li>Inter-Clock paths</li> <li>User Ignored Paths</li> <li>Unconstrained Paths</li> </ul>                          |
| • | Select the longest setup path for clk_out1_clk_core under Intra-Clock Paths.                        | <ul> <li>Review the following:</li> <li>Path properties</li> <li>Confirm the slack calculation for hold time (arrival time – required time)</li> <li>Logic descriptions</li> <li>Element delay and cumulative delay</li> <li>Schematic generation and cross probing to source HDL</li> </ul> |

| Action with Description                                                                                                                                                   | Point of Emphasis and Key Takeaway                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Describe the inter-clock paths and the possible need for synchronization circuits.</li> <li>Select the longest path in the Inter-clock Paths section.</li> </ul> | Review the possible need for synchronization circuits. Review the path to show that they have different clocks on the source and destination flip-flops.                                                                                                                                                                                                                                                     |
| Click <b>Report Clock Interaction</b> to<br>generate a Clock Interaction report.                                                                                          | <ul> <li>Review the following:</li> <li>Color coding for different type of paths</li> <li>Source clock/destination clock chart</li> <li>Right-click options for the paths between each clock domain.</li> </ul>                                                                                                                                                                                              |
| Facilitate an open-ended discussion on fixing the design.                                                                                                                 | <ul> <li>Review the following:</li> <li>Synchronization circuitry</li> <li>Fixing timing problems</li> <li>Need for path-specific constraints</li> <li>If I do all of these things, will I fix all the timing problems?</li> <li>How accurate are these timing numbers?</li> <li>Note: In this demo, all this analysis can be done without having to complete a single implementation (saved huge</li> </ul> |

# **Summary**

This demo illustrated how to create initial clock constraints and verify the clocking structures built into your design using some of the most common reports. It also illustrated the static timing analysis capabilities of the Vivado Design Suite to perform some basic timing verification.

### References:

- Supporting materials
  - Vivado Design Suite User Guide (Using Constraints) (UG903)
  - Vivado Design Suite User Guide (Design Analysis and Closure Techniques) (UG906)